home *** CD-ROM | disk | FTP | other *** search
/ Aminet 28 / Aminet 28 (1998)(GTI - Schatztruhe)[!][Dec 1998].iso / Aminet / dev / src / GLperf3.12-src.lha / GLperf / CopyPixX.c < prev    next >
Encoding:
C/C++ Source or Header  |  1996-08-01  |  3.7 KB  |  102 lines

  1. /*
  2.  * (c) Copyright 1995, Silicon Graphics, Inc.
  3.  * ALL RIGHTS RESERVED
  4.  * Permission to use, copy, modify, and distribute this software for
  5.  * any purpose and without fee is hereby granted, provided that the above
  6.  * copyright notice appear in all copies and that both the copyright notice
  7.  * and this permission notice appear in supporting documentation, and that
  8.  * the name of Silicon Graphics, Inc. not be used in advertising
  9.  * or publicity pertaining to distribution of the software without specific,
  10.  * written prior permission.
  11.  *
  12.  * THE MATERIAL EMBODIED ON THIS SOFTWARE IS PROVIDED TO YOU "AS-IS"
  13.  * AND WITHOUT WARRANTY OF ANY KIND, EXPRESS, IMPLIED OR OTHERWISE,
  14.  * INCLUDING WITHOUT LIMITATION, ANY WARRANTY OF MERCHANTABILITY OR
  15.  * FITNESS FOR A PARTICULAR PURPOSE.  IN NO EVENT SHALL SILICON
  16.  * GRAPHICS, INC.  BE LIABLE TO YOU OR ANYONE ELSE FOR ANY DIRECT,
  17.  * SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY
  18.  * KIND, OR ANY DAMAGES WHATSOEVER, INCLUDING WITHOUT LIMITATION,
  19.  * LOSS OF PROFIT, LOSS OF USE, SAVINGS OR REVENUE, OR THE CLAIMS OF
  20.  * THIRD PARTIES, WHETHER OR NOT SILICON GRAPHICS, INC.  HAS BEEN
  21.  * ADVISED OF THE POSSIBILITY OF SUCH LOSS, HOWEVER CAUSED AND ON
  22.  * ANY THEORY OF LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE
  23.  * POSSESSION, USE OR PERFORMANCE OF THIS SOFTWARE.
  24.  *
  25.  * US Government Users Restricted Rights
  26.  * Use, duplication, or disclosure by the Government is subject to
  27.  * restrictions set forth in FAR 52.227.19(c)(2) or subparagraph
  28.  * (c)(1)(ii) of the Rights in Technical Data and Computer Software
  29.  * clause at DFARS 252.227-7013 and/or in similar or successor
  30.  * clauses in the FAR or the DOD or NASA FAR Supplement.
  31.  * Unpublished-- rights reserved under the copyright laws of the
  32.  * United States.  Contractor/manufacturer is Silicon Graphics,
  33.  * Inc., 2011 N.  Shoreline Blvd., Mountain View, CA 94039-7311.
  34.  *
  35.  * Author: John Spitzer, SGI Applied Engineering
  36.  *
  37.  */
  38.  
  39. /* Define calls if using function pointers or not */
  40. #ifdef FUNCTION_PTRS
  41.   #define COPYPIX_CALL   (*copyPixels)(x, y, width, height, type);
  42.   #if (RASTERPOS_DIM == 2)
  43.     #define RASTERPOS_CALL   (*rasterPos2fv)(dstPtr); dstPtr += 2;
  44.   #else
  45.     #define RASTERPOS_CALL   (*rasterPos3fv)(dstPtr); dstPtr += 3;
  46.   #endif
  47. #else
  48.   #define COPYPIX_CALL   glCopyPixels(x, y, width, height, type);
  49.   #if (RASTERPOS_DIM == 2)
  50.     #define RASTERPOS_CALL   glRasterPos2fv(dstPtr); dstPtr += 2;
  51.   #else
  52.     #define RASTERPOS_CALL   glRasterPos3fv(dstPtr); dstPtr += 3;
  53.   #endif
  54. #endif
  55.  
  56. void FUNCTION (TestPtr thisTest)
  57. {
  58.     CopyPixelsPtr this = (CopyPixelsPtr)thisTest;
  59.     int iterations = this->iterations;
  60.     int numDrawn = this->numDrawn;
  61.     int width = this->copyPixelsWidth;
  62.     int height = this->copyPixelsHeight;
  63.     int type = this->copyPixelsType;
  64.     int i, j;
  65.     GLint x, y;
  66.     GLfloat *dstData = this->traversalData;
  67.     GLint *srcData = this->subImageData;
  68.     GLfloat *dstPtr = dstData;
  69.     GLint *srcPtr = srcData;
  70.   #ifdef FUNCTION_PTRS
  71.    #ifdef WIN32
  72.      void (APIENTRY *copyPixels)(GLint, GLint, GLsizei, GLsizei, GLenum) = glCopyPixels;
  73.     #if (RASTERPOS_DIM == 2)
  74.      void (APIENTRY *rasterPos2fv)(const GLfloat*) = glRasterPos2fv;
  75.     #else
  76.      void (APIENTRY *rasterPos3fv)(const GLfloat*) = glRasterPos3fv;
  77.     #endif
  78.    #else
  79.     void (*copyPixels)(GLint, GLint, GLsizei, GLsizei, GLenum) = glCopyPixels;
  80.     #if (RASTERPOS_DIM == 2)
  81.      void (*rasterPos2fv)(const GLfloat*) = glRasterPos2fv;
  82.     #else
  83.      void (*rasterPos3fv)(const GLfloat*) = glRasterPos3fv;
  84.     #endif
  85.    #endif
  86.   #endif
  87.  
  88.     for (i = iterations; i > 0; i--) {
  89.     for (j = numDrawn; j > 0; j--) {
  90.         RASTERPOS_CALL
  91.         x = *srcPtr++;
  92.         y = *srcPtr++;
  93.         COPYPIX_CALL
  94.     }
  95.     dstPtr = dstData;
  96.     srcPtr = srcData;
  97.     }
  98. }
  99.  
  100. #undef COPYPIX_CALL
  101. #undef RASTERPOS_CALL
  102.